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(54) Encoder with optimally selected codebook 

(57) An encoder of the present invention includes: a 
number G of storage sections (G is an integer equal to 
or greater than 1) for storing a number G of groups of 
data; a Huffman codebook selection section for select- 
ing one of a number H of Huffman codebooks (H is an 
integer equal to or greater than 1) for each of the groups 
of data stored in the respective storage sections, each 
of the Huffman codebooks having a codebook number; 
a number G of Huffman encocfing sections, each of the 
Huffman encoding sections Huffman-encoding a corre- 
sponding one of the G groups of data by using one of 
the Huffman codebooks which is selected by the Huff- 
man codebook selection section for the one group of 
data; and a codebook number encoding section for 
encoding the codebook number of each Huffman code- 
book selected by the Huffman codebook selection sec- 
tion. The Huffman codebook selection section includes 
a code length calculation section for calculating a code 
length which would result from a Huffman encoding 
operation of each of the G groups of data using each 
Huffman codebook, and a control section for selecting 
one of the Huffman codebooks which is suitable for the 
group of data based on the code length calculated by 
the code length calculation section. When the Huffman 
codebook selected is an unsigned codebook, a number 
of bits required for sign information has previously been 
added to the code length calculated by the code length 
calculation section. 
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Description 

BACKGROUND OF THE INVENTION 

5 1 . FIELD OF THE INVENTION: 

[0001] The present invention relates to an encoder using Huffman codes. More particularly, the present invention 
relates to an encoder capable of selecting the optima) Huffman codebook from among a plurality of Huffman codebooks 
so as to encode digital data by using the optimally selected Huffman codebook. 

10 

2. DESCRIPTION OF THE RELATED ART: 

[0002] in recent years, efficient audio signal compression methods encode spectral data of quantized audio signals 
by using a Huffman encoding scheme. A conventional data compression method, for example, a data compression 

15 method disclosed in the MPEG2-AAC standard will now be described (see ISO/I EC 13818-7). 

[0003] First, an input PCM (Pulse Code Modulation) signal is converted through an MDCT (Modified Discrete 
Cosine Transform) operation into 1024 elements of frequency spectral data This process is described in detail in 
■ISO/IEC 13818-7 ANNEX B 2.3 FilterBank and block switching" and will not be discussed below. "ISO/IEC 13818-7 
ANNEX B 2.3 FilterBank and block switching" is incorporated by reference in its entirety. 

20 [0004] Then, the 1 024 elements of frequency spectra) data are quantized (converted into integers) by using a non- 
linear quantization method. This process is described in detail in "ISO/IEC 13818-7 ANNEX B 2.7 Quantizing" and will 
not be discussed below. "ISO/IEC 13818-7 ANNEX B 2.7 "Quantizing" is incorporated by reference in its entirety. 
[0005] Next, the 1024 elements of quantized frequency spectral data are grouped into a number of scale factor 
bands (in this specification, a scale factor band (SFB) may also be referred to as a "group of data"). Using a sampling 

25 frequency of 48 kHz, for example, the 1024 elements of quantized frequency spectral data would be grouped into 49 
SFBs. Referring now to Figure 14, the grouping of frequency spectral data is performed as shown in a table 450. For 
example, the frequency spectral data is grouped into SFBs so that SFB0 includes four elements 0-3 of the frequency 
spectral data (as shown in row 451), SFB1 includes four elements 4-7 of the frequency spectral data (as shown in row 
452), and SFB2 includes four elements 8-1 1 of the frequency spectral data (as shown in row 453) (see "ISO/IEC 1 381 8- 

30 7 3.8 Tables"). 

[0006] Referring to Figure 15, a table 500 illustrating frequency spectral data which has been quantized and 
grouped into a number of SFBs (SFBO to SFB(G-1 )) in a process as described above is shown. In Figure 1 5, left column 
501 designated "SFB" shows a number of SFBs (SFBO to SFB(G-1 )), center column 502 designated "spectrum" shows 
frequency spectral data numbers, and right column 503 designated "value" shows the absolute value of each frequency 
35 spectral data. 

[0007] Then, the quantized and grouped frequency spectral data is Huffman-encoded tor each SFB. The Huffman 
encoding operation is performed based on one Huffman codebook which is selected for each SFB from among a plu- 
rality of Huffman codebooks. According to the MPEG2-AAC standard, a Huffman codebook is selected from among 
eleven Huffman codebooks (Huffman codebooks 1-1 1). In the following description, however, only four Huffman code- 

40 books (Huffman codebooks 3-6) are used for the sake of simplicity. 

[0008] Figures 16 to 19 illustrate Huffman codebooks 3-6, respectively. In the Huffman codebooks 3-6 illustrated in 
Figures 16 to 19, respectively, the leftmost column designated "index" shows the index number of each data to be 
encoded, the second column designated "length" shows the code length of each encoded data, and the third column 
designated "codeword (hexadecimal)" shows a hexadecimal representation of each encoded data (codeword). The 

45 Huffman codebooks 3-6 illustrated in Figures 1 6 to 19 each contain the code length of each encoded data (length) and 
a hexadecimal representation of each encoded data (codeword) for index numbers 0-80. 

[0009] In SFBO shown in Figure 15, the largest absolute spectral data value is 4. According to the MPEG2-AAC 
standard, Huffman codebooks that can be selected for an input signal are limited by the largest absolute value of the 
input signal. This limitation is determined by LAV (largest absolute value) as shown in Figure 20. LAV of a Huffman 

so codebook denotes the largest absolute value of input data that can be encoded by using a particular Huffman code- 
book. According to the table shown in Figure 20, when the largest absolute spectral data value in SFBO is 4, Huffman 
codebooks 5 and 6 are the candidate Huffman codebooks. The code length which would result when encoding data 
with the candidate Huffman codebook 5 is compared with the code length which would result when encoding data with 
the candidate Huffman codebook 6. The candidate Huffman codebook that gives the smaller code length is selected. 

55 In this example, where the Huffman codebooks 5 and 6 are candidates, the code length which would result when Huff- 
man-encoding data with the candidate Huffman codebooks is calculated as follows: 
[0010] First, two index values "indexO" and "indexl" are calculated from Expressions (1) and (2) below: 
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indexO = (D0+LAV)*(2*LAV+1) + (D1+LAV) 



(D 



index! = (D2+LAV)*(2*LAV+1) + (D3+LAV) 



(2) 



5 where DO, D1, D2 and D3 respectively denote the four spectral data elements (values) of SFBO. The calculated values 
of IndexO" and "indexl" are used as the index values. The code length 'length - for the candidate Huffman codebooks 
5 and 6 is obtained based on the index values. 

[0011] Referring to Figure 15, substituting the following values into Expressions (1) and (2), Df>=4, D1=-2, D2=0, 
D3=3 and LAV=4, result in index0=74 and index1=43. Referring to the Huffman codebook 5 shown in Rgure 18, a 

io length=1 2 for i ndex0=74 and a length=8 for i ndex 1 =43 can be determined, indicating that the code length would be 20 
(12+6) bits when Huffman-encoding data with the Huffman codebook 5. Referring to the Huffman codebook 6 shown in 
Rgure 19, a length=9 for index0=74 and a length=7 for index1=43 can be determined, indicating that the code length 
would be 1 6 (9+7) bits when Huffman-encoding data with the Huffman codebook 6. Therefore, it is more advantageous 
to select the candidate Huffman codebook 6 for encoding each spectral data included in SFBO. Thus, the Huffman 

15 codebook 6 is selected. 

[001 2] Similarly; for SFB1 , the code length would be 1 8 bits when encoding data with the Huffman codebook 5, and 
13 bits when encoding data with the Huffman codebook 6. Therefore, it is more advantageous to also select the Huff- 
man codebook 6 for encoding each spectral data included in SFB1 . Thus, the Huffman codebook 6 is selected. 
[0013] For SFB2 shown in Rgure 15, whose largest absolute spectral data value is 1 , the Huffman codebooks 3-6 

20 are the candidate Huffman codebooks. For the Huffman codebooks 5 and 6, the code length of Huffman-encoded data 
can be determined as described above; 9 bits for the Huffman codebook 5 and 8 bits for the Huffman codebook 6. 
[0014] For the Huffman codebooks 3 and 4, the code length of Huffman-encoded data is calculated as follows. The 
Huffman codebooks 3 and 4 are so-called "unsigned* codebooks which are used for encoding data without a sign 
(unsigned data). When using an unsigned codebook, the absolute value of input data is Huffman-encoded, while the 

25 number of ignored signs are separately counted and added to the code amount of the Huffman encoding operation. The 
number of ignored signs corresponds to the number of non-zero elements (elements that require a sign) of the data to 
be encoded. The code length which would result when Huffman-encoding data with such an unsigned Huffman code- 
book can be obtained as follows. 

[0015] First, an index value IndexO* is calculated from Expression (3) below: 



where DO, D1 , D2 and D3 respectively denote the four spectral data elements (values) of SFB2, "abs(x)" denotes an 
absolute value of x, " A " denotes an exponentiation, and k=LAV+1 . 

35 [001 6] The calculated value of IndexO" is used as the index value for obtaining "length" for each of Huffman code- 
books 3 and 4. For SFB2 shown in Rgure 15, for example, D0=1 , D1=-1 , D2=1 , D3=0 and LAV=2. Thus, index0=39. 
Referring to the Huffman codebook 3 shown in Rgure 16, a length=6 is determined for index0=39. Since the sign infor- 
mation bits are not included in the codeword obtained from the Huffman codebook 3, sign information is needed to 
restore the code bits. The number of sign information bits needed is equal to the number of non-zero elements among 

40 the four elements in the spectral data of SFB2. SFB2 shown in Rgure 15 includes three non-zero elements. Therefore, 
three sign information bits need to be added to the Huffman-encoded codeword. As a result, the code length of the Huff- 
man-encoded data is 9 (bits) (length=6 + three sign information bits). 

[0017] Referring to the Huffman codebook 4 as shown in Rgure 17, a tength=4 can be determined for index0=39. 
Again, three sign information bits need to be added to length=4. Therefore, the code length of the Huffman-encoded 
45 data is 7 (bits) (length=4 +• three sign information bits). 

[0018] Thus, the code lengths which would result when Huffman-encoding SFB2 with the Huffman codebooks 3, 4, 
5 and 6 are 9, 7, 9 and 8, respectively. Therefore, the Huffman codebook 4 is selected, with which the smallest code 
length is obtained. 

[0019] Similarly, the optimal Huffman codebook is selected and used for Huffman-encoding each of the other SFBs. 
so The Huffman encoding operation, which is simple by itself, is effected by outputting as encoded data a codeword (hex- 
adecimal) for each index number (e.g., indexO, index! , etc., which can be obtained as described above) from the 
selected Huffman codebooks. 

[0020] Then, for each SFB, the codebook number of the selected Huffman codebook is encoded. This operation of 
encoding a Huffman codebook number is performed as follows according to the MPEG2-AAC standard. The codebook 
55 number of the Huffman codebook selected for the SFB of interest is encoded with four bits. Then, a value indicating 
whether the same Huffman codebook is selected for any other SFB which is contiguous with the SFB of interest is 
encoded with five bfts. In the example shown in Rgure 15, the Huffman codebook 6 is selected for contiguous SFBs 
(SFBO and SFB1 ). Therefore, for SFBO, the codebook number of the Huffman codebook 6 (i.e., "6") is encoded with four 
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indexO = abs(D0)*(k*3) + abs(D1)*(k A 2) + abs(D2)*k + abs (D3) 



(3) 



3 



EP 1 047 198 A2 



bits (01 1 0), and the value ("1 ") (which indicates that the same Huffman codebook is aJso selected for the following SFB 
(SFB1 )) is encoded with five bits (00001 ). Next, for SFB2, the Huffman codebook 4 is selected. Therefore, the codebook 
number of the Huffman codebook 4 (i.e., "4") is encoded with four bits (01 00). The following bit stream is dependent on 
the Huffman codebook selected for the following SFB (SFB3), and will not be discussed below. The codebook number 

5 of the selected Huffman codebook is similarly encoded for the subsequent SFBs. 

[0021] A problem associated with the above-described conventional method is that the process of selecting the 
optimal Huffman codebook for each SFB takes a large amount of computation. This problem can be attributed in part 
to the calculation of the number of sign information bits, which is performed each time an unsigned codebook is 
selected. The problem can also be attributed to the operation of obtaining a code length which would result when 

io encoding the SFB of interest with a Huffman codebook, which is performed separately for each of the candidate Huff- 
man codebooks. 

[0022] Another problem associated with the conventional method is that the method may not always select a Huff- 
man codebook that is optimal for an SFB in view of the code amount needed to encode the codebook number of each 
selected Huffman codebook. In other words, the conventional method selects a Huffman codebook for each SFB so as 
is to minimize the code amount of encoded data of that SFB. The conventional method cannot select the optimal Huffman 
codebook so as to minimize the total code amount of all encoded SFBs while taking into consideration the code amount 
needed to encode the codebook number of each selected Huffman codebook. 

SUMMARY OF THE INVENTION 

20 

[0023] Accord] ng to one aspect of this invention, there is provided an encoder including: a number G of storage sec- 
tions (G is an integer equal to or greater than 1 ) for storing a number G of groups of data; a Huffman codebook selection 
section for selecting one of a number H of Huffman codebooks (H is an integer equal to or greater than 1 ) for each of 
the groups of data stored in the respective storage sections, each of the Huffman codebooks having a codebook 

25 number, a number G of Huffman encoding sections, each of the Huffman encoding sections Huffman-encoding a cor- 
responding one of the G groups of data by using one of the Huffman codebooks which is selected by the Huffman code- 
book selection section for the one group of data; and a codebook number encoding section for encoding the codebook 
number of each Huffman codebook selected by the Huffman codebook selection section. The Huffman codebook 
selection section includes a code length calculation section for calculating a code length which would result from a Huff- 

30 man encoding operation of each of the G groups of data using each Huffman codebook, and a control section for select- 
ing one of the Huffman codebooks which is suitable for the group of data based on the code length calculated by the 
code length calculation section. When the Huffman codebook selected is an unsigned codebook, a number of bits 
required for sign information has previously been added to the code length calculated by the code length calculation 
section. 

as [0024] In one embodiment of the invention, the code length calculation section has a table of data including a code 
length previously calculated for each Huffman codebook. 

[0025] According to another aspect of this invention, there is provided an encoder including: a number G of storage 
sections (G is an integer equal to or greater than 1) storing a number G of groups of data; a Huffman codebook selec- 
tion section for selecting one of a number H of Huffman codebooks (H is an integer equal to or greater than 1) for each 

40 of the groups of data stored in the respective storage sections, each of the Huffman codebooks having a codebook 
number; a number G of Huffman encoding sections, each of the Huffman encoding sections Huffman-encoding a cor- 
responding one of the G groups of data by using one of the Huffman codebooks which is selected by the Huffman code- 
book selection section for the one group of data; and a codebook number encoding section for encoding the codebook 
number of each Huffman codebook selected by the Huffman codebook selection section. The Huffman codebook 

45 selection section includes a code length calculation section for calculating a code length which would result from a Huff- 
man encoding operation of each of the G groups of data using each Huffman codebook, and a control section for select- 
ing one of the Huffman codebooks which is suitable for the group of data based on the code length calculated by the 
code length calculation section. The code length calculation section is capable of simultaneously obtaining code 
lengths for a plurality of Huffman codebooks. - - 

so [0026] In one embodiment of the invention, the code length calculation section is adapted to output respective code 
lengths which would result from Huffman encoding operations of the one group of data, for a plurality of Huffman code- 
books. The control section selects one of the Huffman codebooks for which a smallest code length is output from the 
code length calculation section. 

[0027] In one ernbocfiment of the invention, the code length calculation section is adapted to output respective code 
55 lengths which would result from Huffman encoding operations of the one group of data, for a plurality of Huffman code- 
books. The control section selects one of the Huffman codebooks based on the code length of the Huffman codebook 
output from the code length calculation section and in view of the codebook number of the Huffman codebook. 
[0028] In one embodiment of the invention, the control section selects one of the Huffman codebooks for a (g+1 f* 
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group of data (g is an integer such that 1<g<G-1 ) by first obtaining a code length Bmin and another code length Bg, the 
code length Bmin being a code length which would result from a Huffman encoding operation of the (g+1 ) m group of 
data using a Huffman codebook Hmin for which a smallest code length is output from the code length calculation sec- 
tion, and the code length Bg being a code length which would result from a Huffman encoding operation of a gP 1 group 

5 of data using a Huffman codebook Hg which has been selected for the g^ group of data, and then selecting the Huff- 
man codebook Hmin if Bmin<(Bg-A) (A is a predetermined integer) or the Huffman codebook Hg if Bmin>(Bg-A). 
[0029] In one embodiment of the invention, the control section selects one of the Huffman codebooks for which a 
smallest code length is output from the code length calculation section as a Huffman codebook for a first group of data. 
[0030] In one embodiment of the invention, the control section selects one of the Huffman codebooks for a (g-1 f* 

io group of data (g is an integer such that 2<g<G) by first obtaining a code length Bmin and another code length Bg, the 
code length Bmin being a code length which would result from a Huffman encoding operation of the (g-1 J 1 * 1 group of 
data using a Huffman codebook Hmin for which a smallest code length is output from the code length calculation sec- 
tion, and the code length Bg being a code length which would result from a Huffman encoding operation of a g* group 
of data using a Huffman codebook Hg which has been selected for the group of data, and then selecting the Huff- 

is man codebook Hmin if Bmin<(Bg-A) (A is a predetermined integer) or the Huffman codebook Hg if Bmin>(Bg-A). 
[0031] In one embodiment of the invention, the control section selects one of the Huffman codebooks for which a 
smallest code length is output from the code length calculation section as a Huffman codebook for a G th group of data. 
[0032] In one embodiment of the invention, when a same Huffman codebook is selected for two or more contiguous 
groups of data, the codebook number encoding section encodes the codebook number of the Huffman codebook and 

20 the number of the contiguous groups of data with a number of bits equal to the predetermined integer A. 

[0033] In one embodiment of the invention, the H Huffman codebooks are eleven Huffman codebooks used for 
Huffman-encoding of spectral data as defined in the MPEG2 AAC standard. 

[0034] In one embodiment of the invention, the code length calculation section is adapted to output respective code 
lengths which would result when encoding data using Huffman codebooks 1-4 defined in the MPEG2-AAC standard. 

25 The code length calculation section has a first table including respective code lengths which would result when encod- 
ing data by using Huffman codebooks 1 and 2 for a common index value and a second table including respective code 
lengths which would result when encoding data by using Huffman codebooks 3 and 4 for the common index value. 
[0035] In one embodiment of the invention, a number of bits required for sign information has previously been 
added to each of the code lengths for Huffman codebooks 3 and 4 which are included in the second table. 

ao [0036] In one embodiment of the invention, the first table includes respective values of T1(F1(a, b, c, d)) and 
T2(F1(a, b, c, d)) for II, and the second table includes respective values of T3(F2(a, b, c, d)) + nonz(a, b, c, d) and 
T4(F2(a, b, c, d)) + nonz(a, b, c, d) for i2, where: nonz(w, x, y, z) is a function which gives the number of non zero values 
among w, x, y and z; F1 (w, x, y, z) is a function defined as follows: F1 (w, x, y, z) = 27*(w+1 ) + 9*(x+1 ) + 3*(y+1 ) + (z+1 ) 
(where an absolute value of each of w, x, y and z is 1 or less); F2(w, x, y, z) is a function defined as follows: 

35 F2(w, x, y, z) = 27*abs(w) + 9*abs(x) + 3*abs(y) + abs(z) (where an absolute value of each of w, x, y and z is 2 or 
less); abs(x) is a function which gives an absolute value of x; T1 (index) to T4(index) are each a function which gives a 
code length which would result when encoding data by using Huffman codebooks 1 to 4, respectively; a, b, c and d are 
integers representing a group of data; and i1 and i2 are index values calculated as a function of the integers a, b, c and 
d. 

40 [00371 In one embodiment of the invention, i1 = (X A 3)*(a+1 ) + (X*2)*(b+1 ) + X*(c+1 ) + (cM-1 ) , where: X is a posi- 
tive number equal to or greater than 3; i2= (Y*3)*abs(a) + (Y A 2)*abs(b) + Y*abs(c) + abs(d) , where: Y is a positive 
number equal to or greater than 3: and the symbol " A * denotes an exponentiation. 

[0038] In one embodiment of the invention, the index value i1 is obtained through a bit connecting operation of a, 
b, c and d each of which is represented with X bits or more, where X is a positive number equal to or greater than 2. 
45 The index value 12 is obtained through a bit connecting operation of abs(a), abs(b), abs(c) and abs(d) each of which is 
represented with Y bits or more, where Y is a positive number equal to or greater than 2. 

[0039] In one embodiment of the invention, the code length calculation section is adapted to output respective code 
lengths which would result when encoding data using Huffman codebooks 1-4 defined in the MPEG2-AAC standard. 
The code length calculation section has a table of data including respective code lengths which would result when 

so encoding data by using Huffman codebooks 1 to 4 for a common index value 

[0040] In one embodiment of the invention, a number of bits required for sign information has previously been 
added to each of the code lengths for Huffman codebooks 3 and 4 which are included in the table. 
[0041 J In one embodiment of the invention, the table includes respective values of T1 (F1 (a, b, c, d)), T2(F1 (a, b, c, 
d)), T3(F2(a, b, c, d)) +nonz(a, b, c, d) andT4(F2(a, b, c, d)) + nonz(a, b, c, d) for j, where: nonz(w, x, y, z) is afunction 

55 which gives the number of non-zero values among w, x, y and z; F1(w, x, y, z) is a function defined as follows: 
F1(w,x,y, z) = 27*(w+1) + 9*(x+1) + 3*(y+1) + (z+1) (where an absolute value of each of w, x, y and z is 1 or less); 
F2(w, x, y, z) is a function defined as follows: F2(w, x, y, z) = 27*abs(w) + 9*abs(x) + 3*abs(y) + abs(z) (where an 
absolute value of each of w, x, y and z is 2 or less); abs(x) is a function which gives an absolute value of x; T1 (index) to 
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T4{index) are each a function which gives a code length which would result when encoding data by using Huffman 
codebooks 1 to 4, respectively; a, b, c and d are integers representing a group of data; and j is an index value calculated 
as a function of the integers a, b, c and d. 

[0042] In one embodiment of the invention, the index value j is obtained through a bit connecting operation of a, b f 
5 c and d each of which is represented with Y bits or more, where Y is a positive number equal to or greater than 2. 
[0043] In one embodiment of the invention, the code length calculation section is adapted to output respective code 
lengths which would result when encoding data using Huffman codebooks 5-10 defined in the MPEG2-AAC standard. 
The code length calculation section has a first table including respective code lengths which would result when encod- 
ing data by using Huffman codebooks 5 and 6 for a common index value, a second table including respective code 
10 lengths which would result when encoding data by using Huffman codebooks 7 and 8 for a common index value, and a 
third table including respective code lengths which would result when encoding data by using Huffman codebooks 9 
and 1 0 for a common index value. 

[0044] (n one embodiment of the invention, a number of bits required for sign information has previously been 
added to each of the code lengths for Huffman codebooks 7 and 8 which are included in the second table. A number of 
15 bits required for sign information has previously been added to each of the code lengths for Huffman-codebooks 9 and 
1 0 which are included in the third table. 

[0045] In one embodiment of the invention, the first table includes respective values of T5(F3(a v b)) and T6(F3(a, 
b)) for i3, the second table includes respective values of T7(F4(a, b)) + nonz(a, b) and T8(F4(a, b)) + nonz(a, b) for i4, 
and the third table includes respective values of T9(F5(a, b)) + nonz(a, b) and T10(F5(a, b)) + nonz(a, b) for i5, where 

20 nonz(x, y) is a function which gives the number of non-zero values among x and y; F3(x, y) is a function defined as fol- 
lows: F3(x, y) = 9*(x+4) + (y+4) (where an absolute value of each of x and y is 4 or less); F4(x, y) is a function defined 
as follows: F4(x, y) = 8*abs(x) + abs(y) (where an absolute value of each of x and y is 7 or less); F5(x, y) is a function 
defined as follows: F5(x, y) = 13*abs(x) + abs(y) (where an absolute value of each of x and y is 12 or less): abs (x) is 
a function which gives an absolute value of x; T5(index) to T10(index) are each a function which gives a code length 

25 which would result when encoding data by using Huffman codebooks 5 to 10 defined in the MPEG2-AAC standard, 
respectively; a and b are integers representing a group of data; and i3, i4 and "6 are index values calculated as a func- 
tion of the integers a and b. 

[0046] In one embodiment of the invention, i3 = X*(a+4) + (b+4) , where X is a positive number equal to or greater 
than 9; i4 = Y*abs(a) + abs(b) , where Y is a positive number equal to or greater than B; and i5 = Z*abs(a) + abs(b) , 

30 where Z is a positive number equal to or greater than 13. 

[0047] In one embodiment of the invention, the index value i3 is obtained through a bit connecting operation of a 
and b each of which is represented with X bits or more, where X is a positive number equal to or greater than 4. The 
index value i4 is obtained through a bit connecting operation of a and b each of which is represented with Y bits or more, 
where Y is a positive number equal to or greater than 4. The index value i5 is obtained through a bit connecting opera- 

35 tion of a and b each of which is represented with Z bits or more, where Z is a positive number equal to or greater than 5. 
[0048] In one embodiment of the invention, the code length calculation section is adapted to output respective code 
lengths which would result when encoding data using Huffman codebooks 5-10 defined in the MPEG2-AAC standard. 
The code length calculation section has a table including respective code lengths which would result when encoding 
data by using Huffman codebooks 5 to 10 for a common index value. 

40 [0049] In one embodiment of the invention, a number of bits required for sign information has previously been 
added to each of the code lengths for Huffman codebooks 7 to 10 which are included in the table. 
[0050] In one embodiment of the invention, the table includes respective values of T5(F3(a, b)), T6(F3(a, b)), 
T7(F4(a, b)) + nonz(a, b), T8(F4{a, b)) + nonz(a, b), T9(F5(a, b)) + nonz(a, b) and T10(F5(a, b)) + nonz(a, b) for k, 
where: nonzfc y) is a function which gives the number of non-zero values among x and y; F3(x, y) is a function defined 

45 as follows: F3(x, y) = 9*(x+4) + (y+4) (where an absolute value of each of x and y is 4 or less); F4 (x, y) is a function 
defined as follows: F4<x, y) = 8*abs(x) + abs(y) (where an absolute value of each of x and y is 7 or less); F5(x, y) is a 
function defined as follows: F5(x, y) = 13*abs(x) + abs(y) (where an absolute value of each of x and y is 12 or less); 
abs(x) is a function which gives an absolute value of x; T5(index) to T1 0(index) are each a function which gives a code 
length which would result when encoring data by using Huffman codebooks 5 to 10 defined in the M P EG2-AAC stand- 

so ard, respectively; a and b are integers representing a group of data; and k is an index value calculated as a function of 
the integers a and b. 

[0051] In one embotfiment of the invention, the index value k is obtained through a bit connecting operation of a and 
b each of which is represented with Z bits or rncre, where Z is a positive number equal to or greater than 5. 
[0052] In one ernbodiment of the invention, the code length calculation section is adapted to output an invalid signal 
55 which indicates that a Huffman codebook is invalid when an input data value is outside a variable range within which a 
code length can be calculated using the Huffman codebook. The control section is adapted not to select a Huffman 
codebook when the control section receives an invalid signal for the Huffman codebook. 

[0053] In one embodiment of the invention, the value of the function T1 (F1 (a, b, c, d)) and the value of the function 
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T2(F1(a, b, c, d)) are stored respectively on a MSB side and on a LSB side with respect to the index value i1 , with at 
least ml bits of "0" (ml is a positive integer) being inserted between the value of the function T1 and the value of the 
function T2. The value of the function T3(F2(a, b, c, d)) + nonz(a, b, c, d) and the value of the function T4(F2(a, b, c, d)) 
+ nonz(a, b, c, d) are stored respectively on a MSB side and on a LSB side with respect to the index value i2, with at 

5 least ml bits of '0' being inserted between the value of the function T3 and the value of the function T4. 

[0054] In one embodiment of the invention, the value of the function T1(F1(a, b, c, d)), the value of the function 
T2(F1 (a, b, c, a)), the value of the function T3(F2(a, b, c, d)) + nonz(a, b, c, d) and the value of the function T4(F2(a, b, 
c, d)) + nonz(a, b, c, d) are stored in this order from a MSB side to a LSB side with respect to the index value j, with at 
least m 1 bits of "0* (ml is a positive integer) being inserted between the value of T1 and the value of T2, between the 

10 value of T2 and the value of T3, and between the value of T3 and the value of T4. 

[0055] In one embodiment of the invention, the value of ml is an integer value obtained by rounding up a value of 
the logarithm of 2 to the base of n1 (log^nl)), where n1 is a value obtained by dividing a maximum number of data 
included in each group among the G groups of data by 4. 

[0056] In one embodiment of the invention, the value of the function T5(F3(a, b)) and the value of the function 
is T6(F3(a, b)) are stored respectively on a MSB side and on a LSB side with respect to the index value i3, with at least 
m2 bits of "0" (m2 is a positive integer) being inserted between the value of the function T5 and the value of the function 
T6. The value of the function T7(F4(a, b)) + nonz(a, b) and the value of the function T8(F4(a, b)) + nonz(a, b) are stored 
respectively on a MSB side and on a LSB side with respect to the index value i4, with at least m2 bits of *0° being 
inserted between the value of the function 77 and the value of the function TB. The value of the function T9(F5(a, b)) + 
20 nonz(a, b) and the value of the function T1 0(F5(a, b)) + nonz(a, b) are stored respectively on a MSB side and on a LSB 
side with respect to the index value *i5, with at least m2 bits of "0" being inserted between the value of the function T9 
and the value of the function T1 0. 

[0057] In one embodiment of the invention, the value of the function 75(F3{a, b)), the value of the function T6(F3(a, 
b)), the value of the function T7(F4(a f b)) + nonz(a, b), the value of the function TB(F4(a, b)) + nonz(a, b), the value of 
25 the function T9(F5(a, b)) + nonz(a, b) and the value of the function T10(F5(a, b)) + nonz(a, b) are stored in this order 
from a MSB side to a LSB side with respect to the index value k, with at least m2 bits of "0" (m2 is a positive integer) 
being inserted between the value of T5 and the value of T6, between the value of T6 and the value of T7, between the 
value of T7 and the value of T8, between the value of TB and the value of T9, and between the value of T9 and the value 
ofT10. 

30 [0058] In one embodiment of the invention, the value of m2 is an integer value obtained by rounding up a value of 
the logarithm of 2 to the base of n2 (log^n2)), where n2 is a value obtained by dividing a maximum number of data 
included in each group among the G groups of data by 2. 

[0059] Thus, the invention described herein makes possible the advantages of providing an encoder capable of 
selecting the optimal Huffman codebook from among a plurality of Huffman codebooks so as to encode digital data by 
35 using the optimally selected Huffman codebook. The encoder is also capable of selecting the optimal Huffman code- 
book within a reduced amount of time and efficiently encoding the digital data with a small amount of calculation. 
[0060] This and other advantages of the present invention will become apparent to those skilled in the art upon 
reading and understanding the following detailed description with reference to the accompanying figures. 

40 BRIEF DESCRIPTION OF THE DRAWINGS 

[0061] 

Figure 1 is a block diagram illustrating a configuration of an encoder 10 of the present invention; 

45 

Figure 2 illustrates a table 200 stored in a table memory provided in a first code length calculator 114; 

Figure 3 illustrates a table 400 stored in a table memory provided in a second code length calculator 115; 

so Figure 4 illustrates a configuration of a Huffman codebook selector 1 08 for selecting one of Huffman codebooks 1 - 
4; 

Figure 5 illustrates a configuration of an alternative first code length calculator 114* for calculating the code length 
which would result when using Huffman codebooks 1-4; 

55 

Figure 6 illustrates a configuration of a code length calculator 1 30 for calculating the code length which would result 
when using Huffman codebooks 5-10; 
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Figure 7 illustrates a configuration of an alternative code length calculator 1 20 for calculating the code length which 
would result when using Huffman codebooks 5-10; 

Figure 8 illustrates the contents of a table memory used for calculating respective code lengths for Huffman code- 
5 books 1-4; 

Figure 9 illustrates a structure of a common table 1100 shown in Figure 8; 

Figure 1 0 illustrates the contents of a table memory used for calculating respective code lengths for Huffman code- 
to books 5-10; 

Figure 11 illustrates a structure of a common table 1300 shown in Figure 10; 

Figure 12 illustrates the contents of a table memory used for calculating respective code lengths for Huffman code- 
rs books 5-10; 

Rgure 13 illustrates a structure of a common table 1500 shown in Figure 12; 

Figure 14 illustrates a table 450 which defines grouping of quantized spectral data; 

20 

Rgure 15 illustrates a table 500 of frequency spectral data which has been quantized and grouped into a number 
of SFBs; 

Rgure 16 illustrates the contents of a first Huffman codebook 104 (Huffman codebook 3 of the MPEG2-AAC stand- 
as ard); 

Rgure 17 illustrates the contents of a second Huffman codebook 105 (Huffman codebook 4 of the MPEG2-AAC 
standard); 

ao Rgure 18 illustrates the contents of a third Huffman codebook 106 (Huffman codebook 5 of the MPEG2-AAC 
standard); 

Rgure 19 illustrates the contents of a fourth Huffman codebook 107 (Huffman codebook 6 of the MPEG2-AAC 
standard); and 

35 

Rgure 20 shows a table 1000 of spectrum Huffman codebook parameters used in an encoding scheme of the 
MPEG2-AAC standard. 

DESCRIPTION OF THE PREFERRED EMBODIMENTS 

40 

[0062] various embodiments of the present invention will now be described with reference to the accompanying 
drawings. The following embodiments are basically directed to an encoder for generating encoded data according to 
the MPEG2-AAC standard. While the MPEG2-AAC standard uses eleven Huffman codebooks, only four of the Huffman 
codebooks defined in the MPEG2-AAC standard (Huffman codebooks 3-6) are used for the sake of simplicity. Thus, in 
45 the following embodiments, a process of encoding quantized spectral data by using the Huffman codebooks 3-6 will be 
described in detail. 

(Embodment 1) 

r 4 \ »• i ' * «iv - r - • > ..... * , t 

so [0063] Rgure 1 illustrates a configuration of an encoder 10 according to Embodiment 1 of the present invention. 
The encoder 10 includes a number of "G" memories 100 to 103, a number of TT Huffman codebooks 104 to 107, a 
Huffman codebook selector 108, a number of "G" Huffman encoders 109 to 11 2, and an codebook number encoder 113 
(G and H are each an integer equal to or greater than 1). 

[0064] A predetermined number of elements of spectral data are provided, each of which has been quantized. The 
55 elements of spectral data are grouped into a number of "G" "groups of data* (also referred to as "scale factor bands" or 
"SFBs") These SFBs are stored in the memories 100 to 103, respectively. The SFBs stored in the memories 100 to 103 
are input respectively to the Huffman encoders 109 to 112 and to the Huffman codebook selector 108. 
[0065] The Huffman codebook selector 1 08 selects one of the "H" Huffman codebooks 104 to 1 07 which is suitable 
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for each SFB. The Huffman codebook selector 108 outputs the contents of the selected Huffman codebooks to the Huff- 
man encoders 109 to 112, respectively, and the codebook numbers of the selected Huffman codebooks to the code- 
book number encoder 113. The Huffman encoders 109 to 112 encode and output the SFBs stored in the memories 100 
to 103 by using the respective Huffman codebooks selected by the Huffman codebook selector 108. The codebook 

5 number encoder 113 encodes and outputs the codebook number of each Huffman codebook selected. 

[0066] The first memory 100 stores a first SFB (SFBO) among the "G" SFBs. Similarly, the second memory 101 
stores a second SFB (SFB1 ), and the third memory 102 stores a third SFB (SFB2), and so on. Finally, the G m memory 
103 stores the G m SFB (SFB(G-1)). The grouping of data is a known technique as done in an encoding method accord- 
ing to the MPEG2-AAC standard. As discussed in the description of the prior art, this can be done according to the table 

io 450 of Figure 14. 

[0067] The "H" Huffman codebooks 104 to 107 are defined in the MPEG2-AAC standard for Huffman-encoding 
spectral data by an encoding scheme according to the MPEG2-AAC standard. As mentioned above, the number of "H" 
Huffman codebooks used in the embodiments to be described below is 4. The first to fourth Huffman codebooks 104 
to 107 are defined as Huffman codebooks 3 to 6, respectively, in the MPEG2-AAC standard. 
is [0068] The Huffman codebook selector 1 08 is adapted to select one of the four Huffman codebooks 104 to 1 07 that 
is optimal for Huffman-encoding each of the SFBs stored in the "G memories 100 to 103. The Huffman codebook selec- 
tor 108 includes a first code length calculator 114, a second code length calculator 115 and a controller 1 16. 
[0069] The first code length calculator 114 simultaneously calculates the code length (the number of bits) which 
would result from a Huffman encoding operation of one of the SFBs stored in the G memories 100 to 103 using the first 
20 Huffman codebook 104 (Huffman codebook 3) and that which would result from a Huffman encoding operation of the 
SFB using the second Huffman codebook 105 (Huffman codebook 4). Similarly, the second code length calculator 115 
simultaneously calculates the code length which would result from a Huffman encoding operation of one of the SFBs 
stored in the G memories 100 to 103 using the third Huffman codebook 106 (Huffman codebook 5) and that which 
would result from a Huffman encoding operation of the SFB using the fourth Huffman codebook 107 (Huffman code- 
cs book 6). The controller 116 inputs each of the SFBs stored in the G memories 100 to 103 to one of the two code length 
calculators 114 and 115, and selects one of the Huffman codebooks that is optimal for a Huffman encoding operation 
of each SFB based on the outputs from the two code length calculators 114 and 115. 

[0070] Figure 2 shows a table 200 which is stored in a table memory provided for in the first code length calculator 
114. The table 200 shows the code length or the number of bits (in the column "length of HCB3") which would result 

3D from a Huffman encoding operation of an input SFB using the first Huffman codebook 104 (Huffman codebook 3) and 
the code length or the number of bits (in the column "length of HCB4") which would result from a Huffman encoding 
operation of the SFB using the second Huffman codebook 105 (Huffman codebook 4), for each index value shown in 
the column "index" which is used as an address in the table 200. The index value is calculated as a function of the spec- 
tral data elements (values) contained in each input SFB. 

35 [0071 ] Figure 3 shows a table 400 which is stored in a table memory provided for in the second code length calcu- 
lator 115. The table 400 shows the code length or the number of bits fin the column "length of HCB5") which would 
result from a Huffman encoding operation of an input SFB using the third Huffman codebook 106 (Huffman codebook 
5) and the code length or the number of bits (in the column "length of HCB6") which would result from a Huffman encod- 
ing operation of the SFB using the fourth Huffman codebook 107 (Huffman codebook 6), for each index value shown in 

40 the column "index" which is used as an address in the table 400. Again, the index value is calculated as a function of 
the spectral data elements (values) contained in each input SFB. 

[0072] The first Huffman encoder 109 (Figure 1) Huffman-encodes the first group of spectral data (SFBO) by using 
a Huffman codebook optimally selected by the Huffman codebook selector 108 for the first group of spectral data 
(SFBO). Similarly, the second Huffman encoder 110 Huffman-encodes the second group of spectral data (SFB1) by 
45 using a Huffman codebook optimally selected for the second group of spectral data (SFB1 ), and so on. Finally, the G m 
Huffman encoder 112 Huffman-encodes the G m group of spectral data (SFB(G-1)) by using a Huffman codebook opti- 
mally selected for the G^ group of spectral data (SFB(G-1 )). 

[0073] The codebook number encoder 113 encodes the codebook number of a Huffman codebook optimally 
selected by the Huffman codebook selector 108 for each SFB. 
so [0074] Next, the process of grouping input spectral data into SFBs and storing the SFBs into memories will be 
described. 

[0075] Figure 1 4 shows the table 450 which defines the grouping of 1 024 elements of quantized frequency spectral 
data into SFBs. The 1024 elements of quantized frequency spectral data are grouped into SFBO to SFB48 as shown in 
Figure 14. In Figure 14, the left column "SFB" shows SFB numbers, and the right column "offset" shows the element 
55 number of the first spectral data element contained in each SFB. Note that the table is provided in 2 columns for spatial 
purposes. 

[0076] The table 450 shown in Figure 14 is used in a case where the sampling frequency is 48 kHz, so that the 1 024 
elements of quantized frequency spectral data are grouped into 49 SFBs (thus, G=49). Specifically, the first group of 
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data (SFBO) contains four spectral data elements 0-3, the second group of data (SFB1 ) contains four spectral data ele- 
ments 4-7, the third group of data (SFB2) contains four spectral data elements 8-1 1 , and so on. The 49 SFBs are stored 
in 49 memories 100 to 103, respectively. For more details, see "ISO/lEC 13818-7 3.8 Tables". 
[0077] Figure 15 illustrates the table 500 of frequency spectral data which has been quantized and grouped into a 

5 number of SFBs (SFBO to SFB(G-1 )). In the table 500, the left column 501 "SFB" shows SFB numbers, and the center 
column 502 "spectrum" shows element numbers of the spectral data elements, and the right column 503 "value" shows 
the values of the respective spectral data elements. In Figure 15, the row 550 corresponds to data of the first group 
(SFBO) stored in the first memory 100 (Figure 1), the row 551 corresponds to data of the second group (SFB1) stored 
in the second memory 101, and the row 552 corresponds to data of the third group (SFB2) stored in the third memory 

w 102. 

[0078] Thus, the quantized spectral data is grouped into SFBO to SFB(G-1), as shown in Figure 15, which are then 
Huffman-encoded by the G Huffman encoders 109 to 112, respectively. Each SFB is Huffman-encoded based on one 
of the four Huffman codebooks 104 to 107 optimally selected for the SFB. 

[0079] Figures 16 to 19 shows the contents of the first to fourth Huffman codebooks 104 to 1 07 which correspond 
15 to Huffman codebooks 3-6 defined in the MPEG2-AAC standard, respectively. As discussed in the description of the 
prior art, in each of the Huffman codebooks 3-6 shown in Figures 16 to 19, a column 300 "index" shows index values 
of data to be encoded, a column 301 "length" shows the code length (the number of bits) of encoded data for each index 
value, and a column 302 "codeword (hexadecimal)" shows encoded data (codeword) in a hexadecimal representation. 
Each of the Huffman codebooks 3-6 shown in Figures 16 to 19 shows the code length (the column 301 "length") and 
20 the hexadecimal representation (the column 302 "codeword") of encoded data for each of index values (the column 300 
"index") ranging from 0 to 80. 

[0080] Referring again to Figure 1 , the operation of the encoder 10 having a configuration as described above will 
now be described. 

[0081] First, the controller 116 receives four spectral data elements from the first memory 100. The controller 116 
25 selects one of the first code length calculator 114 and the second code length calculator 115 to which to output the 
received spectral data based on the largest absolute value (LAV) of the spectral data (one of the "spectrum Huffman 
codebook parameters"). As will be described below, according to the MPEG2-AAC standard, Huffman codebooks that 
can be selected for an input signal are limited by the largest absolute value of the input signal. 
[0082] Figure 20 shows a table 1000 of spectrum Huffman codebook parameters used in the encoding scheme of 
so the MPEG2-AAC standard. The table 1000 contains various Huffman codebook attributes (or parameters) in a tabular 
form. In the table 1000, the leftmost column 1001 "Codebook Number, i" shows Huffman codebook numbers, the sec- 
ond column 1002 "Unsigned_cb[i]" indicates whether the Huffman codebook is an unsigned codebook ("1 ") or a signed 
codebook ("0"), and the fourth column 1004 "LAV for codebook" shows the largest absolute value (LAV) of input data 
for which a Huffman codebook can be selected. 
35 [0083] Referring to Figure 15, the first group of spectral data (SFBO) has an LAV of 4. Therefore, it can be deter- 
mined from the fourth column 1004 "LAV for codebook" in the table 1000 of Figure 20 that the third Huffman codebook 
106 (Huffman codebook 5 of the MPEG2-AAC standard) and the fourth Huffman codebook 107 (Huffman codebook 6 
of the MPEG2-AAC standard) are candidates for SFBO. 

[0084] Therefore, the controller 116 inputs the group of spectral data received from the first memory 1 00 (SFBO) to 
40 the second code length calculator 115, which stores code length data for the third and fourth Huffman codebooks 106 
and 107. The second code length calculator 115 operates as follows. First, the second code length calculator 115 cal- 
culates two index values "indexO" and "indexl " to be used as addresses in the table 400 shown in Figure 3 as shown in 
Expressions (4) and (5) below: 

45 index0==(DOUAVl*(2n^V+1) + (D1+LAV) (4) 

indexl = (D2+LAvy(2*LAV+1) + (D3+LAV) (5) 

where DO, D1, D2 and D3 respectively denote the four spectral data elements (values) of the input group of data 
so (SFBO). 

[0085] Once the index values "indexO" and Indexl" are calculated, the second code length calculator 115 obtains 
from the table 400 shown in Figure 3 the code length (the number of bits) which would result from a Huffman encoding 
operation of SFBO using the third Huffman codebook 106 (Huffman codebook 5) and that which would result from a 
Huffman encoding operation of SFBO using the fourth Huffman codebook 107 (Huffman codebook 6). 
55 [0086] In the table 400 shown in Figure 3, the left column 401 labeled "index" shows the index value which is used 
as an address in the table 400, the center column 402 labeled "length of HCB5" shows the code length which would 
resutt from a Huffman encoding operation of an input SFB using the third Huffman codebook 106 (Huffman codebook 
5), and the right column 403 labeled "length of HCB6" shows the code length which would result from a Huffman encod- 
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ing operation of an input SFB using the fourth Huffman codebook 107 (Huffman codebook 6). 
[0087] The Huffman codebooks 5 and 6 stored in the second code length calculator 115 are each a signed code- 
book which is used to Huffman-encode signed data Therefore, in the table 400 shown in Figure 3, the columns 402 and 
403 ("length of HCB5" and "length of HCB6") each shows the number of bits corresponding to the code length which 
5 would result from a Huffman encoding operation of each SFB. 

[0088] Thus, by using the table 400 shown in Figure 3, it is possible to obtain, for one index value, the code length 
which would result from a Huffman encoding operation using Huffman codebook 5 and the code length which would 
result from a Huffman encoding operation using Huffman codebook 6. 

[0089] In the first group of spectral data (SFBO) shown in Rgure 15, the spectral data elements respectively have 
io values as follows: D0=4, D1 =-2, D2=0 and D3=3. Thus, LAV=4. Therefore, indexO=74 and index 1=43. Referring to the 
table 400 of Rgure 3, for index0=74, the code length ("length of HC65") which would result when encoding SFBO using 
the Huffman codebook 5 is 12 bits and the code length (length of HCB6*) which would result when encoding SFBO 
using the Huffman codebook 6 is 9 bits. For index1=43, the code length ("length of HCB5") which would result when 
encoding SFBO using the Huffman codebook 5 is 8 bits and the code length ("length of HCB6") which would result when 
15 encoding SFBO using the Huffman codebook 6 is 7 bits. 

[0090] Thus, the second code length calculator 115 calculates two index values "indexO" and "index 1 " for an input 
group of data (SFBO in this example), and obtains the code length which would result when encoding SFBO using Huff- 
man codebook 5 and the code length which would result when encoding SFBO using Huffman codebook 6. Then, the 
second code length calculator 115 calculates the sum of two code lengths (one for indexO and another for index 1) for 
20 each of the Huffman codebooks 5 and 6. In this example, the total code length for Huffman codebook 5 is 20 (12+8) 
bits, and the total code length for Huffman codebook 6 is 1 6 (9+7) bits. The calculated total code length (the number of 
bits) for each Huffman codebook is output to the controller 116. 

[0091] Then, the controller 116 selects one of the Huffman codebooks 5 and 6 based on the total code length for 
each of the Huffman codebook 5 and 6 output from the second code length calculator 115. Thus, in this example, the 

25 Huffman codebook 6, which would give a smaller code length for SFBO, is selected. 

[0092] One of the Huffman codebook 5 and 6 is selected from the second group of spectral data (SFB1) shown in 
Rgure 15 which is stored in the second memory 101 in a manner simitar to that for the first group of spectral data 
(SFBO). Since LAV=4 for SFB1 , the controller 116 again selects the second code length calculator 1 1 5 as for SFBO, and 
the second code length calculator 115 operates in a manner similar to that described above for SFBO. Then, the second 

30 code length calculator 115 outputs to the controller 116 the code length which would result when encoding SFB1 using 
Huffman codebook 5 (18 bits in this example), and the code length which would result when encoding SFB1 using Huff- 
man codebook 6 (13 bits in this example). Thus, the controller 116 selects the Huffman codebook 6, which would give 
a smaller code length for SFB1 . 

[0093] Then, the controller 116 receives the third group of spectral data (SFB2), as shown in Rgure 15, from the 
35 third memory 102. For the third group of spectral data (SFB2), LAV=1 . Referring to the column 1004 "LAV for codebook" 
of the table 1000 shown in Rgure 20, it is indicated that Huffman codebooks 3 and 4, which are unsigned codebooks, 
and Huffman codebook 5 and 6, which are signed codebooks, can be selected for SFB2. Therefore, the controller 116 
outputs the received group of spectral data (SFB2) both to the first code length calculator 114, which contains data for 
Huffman codebooks 3 and 4, and to the second code length calculator 115, which contains data for Huffman codebook 
40 5 and a 

[0094] The second code length calculator 1 15 obtains from the table 400 shown in Rgure 3 the code length which 
would result from a Huffman encoding operation using each of the Huffman codebook 5 and 6, in a manner similar to 
that described above. The process of obtaining the code length is as described above and will not be further described 
below. The calculated code length which would result when encoding SFB2 using Huffman codebook 5 is 9 bits and the 

45 code length which would result when encoding SFB2 using Huffman codebook 6 is 8 bits. 

[0095] The first code length calculator 114 operates as follows to calculate the code length (the number of bits) 
which would result from a Huffman encoding operation of SFB2 using each of Huffman codebooks 3 and 4. First, the 
first code length calculator 114 receives from the controller 116 the four spectra) data elements contained in the third 
group of spectral data (SFB2) stored in the third memory 1 02. Then, the first code length calculator 114 calculates one 

so index value "indexO" according to Expression (6) below: 

indexO = abs(D0)*(k*3) + abs(D1 )*(k A 2) + abs(D2f k + abs (D3) (6) 

where DO, D1, D2 and 03 respectively denote the four spectral data elements (values) of SFB2, "abs(x)* denotes an 
55 absolute value of x, * A " denotes an exponentiation, and k=LAV+1 . 

[0096] Once the index value "indexO* is calculated, the first code length calculator 114 obtains from the table 200 
shown in Rgure 2 the code length (the number of bits) which would result from a Huffman encoding operation of SFB2 
using the first Huffman codebook 104 (Huffman codebook 3) and that which would result from a Huffman encoding 
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operation of SFB2 using the second Huffman codebook 105 (Huffman codebook 4), based on the calculated index 
value "indexO". 

[0097] In the table 200 of Figure 2, the left column 201 labeled "index* shows the index value which is used as an 
address in the table 200, the center column 202 labeled length of HCB3* shows the code length (the number of bits) 

5 which would result from a Huffman encoding operation of an input SFB using the first Huffman codebook 104 (Huffman 
codebook 3), and the right column 203 labeled "length of HCB4" shows the code length (the number of bits) which 
would result from a Huffman encoding operation of an input SFB using the second Huffman codebook 105 (Huffman 
codebook 4). Thus, by using the table 200 shown in Figure 2, it is possible to obtain the code length (the number of bits) 
which would result from a Huffman encoding operation using Huffman codebook 3 and the code length which would 

10 result from a Huffman encoding operation using Huffman codebook 4, for one index value. 

[0098] The table 200 of Figure 2 contains the code length (the number of bits) which would result from a Huffman 
encoding operation using each of Huffman codebooks 3 and 4, which are defined in the MPEG2-AAC standard, for 
each index value. However, referring to the table 1000 of Figure 20, the column 1002 "unsigned_cb[i]" shows "1" for 
both of the Huffman codebooks 3 and 4, indicating that the Huffman codebooks 3 and 4 are unsigned codebooks. 

15 Therefore, the column 202 "length of HCB3" contains the sum of the code length (the number of bits) which would result 
from a Huffman encoding operation using the Huffman codebook 3 defined in the MPEG2-AAC standard and the 
number of non-zero values (i.e., values which require sign information bits) contained in the input group of spectral data. 
The same applies to the column 203 "length of HCB4". 

[0099] In SFB2 as shown in Figure 15, the spectral data elements respectively have values as follows: D0=1 , D1=- 
20 t , D2=1 and D3=0. Thus, LAV=2. Therefore, index0=39. Referring to the table 200 of Figure 2, for index0=39, the col- 
umn 202 "length of HCB3" (the sum of the code length which would result from a Huffman encoding operation using the 
Huffman codebook 3 and the number of non-zero values) shows a value of 9, and the column 203 "length of HCB4" 
(the sum of the code length which would result from a Huffman encoding operation using the Huffman codebook 4 and 
the number of non-zero values) shows a value of 7. 
25 [0100] Then, the first code length calculator 114 outputs to the controller 116 the code length which would result 
when encoding SFB2 using Huffman codebook 3 (9 bits in this example), and the code length which would result when 
encoding SFB2 using Huffman codebook 4 (7 bits in this example). Similarly, the second code length calculator 115 out- 
puts to the controller 116 the code length which would result when encoding SFB2 using Huffman codebook 5 (9 bits 
in this example), and the code length which would result when encoding SFB2 using Huffman codebook 6 (8 bits in this 
X example). The controller 116 selects one of the Huffman codebooks based on the outputs from the first and second 
code length calculators 114 and 115. In this example, the controller 116 selects the Huffman codebook 4, which would 
give a smaller code length for SFB2. 

[0101] In the process of obtaining the code length which would result from a Huffman encoding operation of the 
third group of spectral data (SFB2) stored in the third memory 1 02, the controller 116 may activate the first code length 
35 calculator 114 and the second code length calculator 115 either in parallel or in series. Where the Huffman codebook 
selector 108 is implemented by software, the code length calculators 114 and 1 1 5 will likely be activated in series. How- 
ever, where the Huffman codebook selector 108 is implemented by hardware, the code length calculators 114 and 115 
are activated preferably in parallel so as to realize a high-speed process. 

[0102] Similarly, the Huffman codebook selector 108 selects an optimal Huffman codebook for each of the G 

40 groups of spectral data (SFBs), and each of the groups of spectral data (SFBs) is Huffman-encoded by a corresponding 
one of the Huffman encoders 109 to 112 using the Huffman codebook selected for the group of spectral data (SFB). 
The Huffman encoding operation itself is similar to the conventional Huffman encoding operation, and is performed by 
o inputting as encoded data a codeword from the column "codeword" of the selected Huffman codebook for the calcu- 
lated index value (e.g., "indexO", "index! \ etc.). 

45 [0103] Then, the codebook number of each Huffman codebook selected for a group of spectral data (SFB) is 
encoded by the codebook number encoder 113. According to the M P EG2-AAC standard, the codebook number of each 
Huffman codebook selected for a group of spectral data (SFB) "is encoded with four bits. When the same Huffman code- 
book is selected for two or more contiguous groups of spectral data (SFBs), the number of the contiguous groups of 
spectral data (SFBs) is encoded wfth five bits. . .. 

so [0104] In the example shown in Figure 1 5, the Huffman codebook 6 is selected for both SFBO and SFBt . Therefore, 
the codebook number of the Huffman codebook 6 (i.e. "6") is first encoded with four bits (01 1 0), and then the value "1" 
(which indicates that there is another SFB (SFBt) in addition to the SFB of interest (SFBO) for which the Huffman code- 
book 6 is selected) is encoded with five bits (00001). Next, for SFB2, the Huffman codebook 4 is selected. Therefore, 
the codebook number of the Huffman codebook 4 (Le., "4") is encoded wfth four bits (01 00). The following bit stream is 

55 dependent on the Huffman codebook selected for the following SFB (SFB3). The codebook number of the selected 
Huffman codebook is simi tarty encoded for the subsequent SFBs. 

[0105] As described above, according to the present embodiment, it is possible to simultaneously obtain code 
lengths which would result from Huffman encoding operations for different Huffman codebooks. Moreover, even when 
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the selected Huffman codebook is an unsigned codebook, it is possible to obtain from a single table the sum of the code 
length which would result from a Huffman encoding operation using the selected Huffman codebook and the number of 
bits required for sign information. Thus, it is possible to substantially reduce the amount of computation required for the 
Huffman encoding operation. 

5 

(Embodiment 2) 

[0106] Embodiment 2 of the present invention will now be described The configuration and operation of the 
encoder 10 and the grouping of the spectral data are similar to those described above in Embodiment 1 , and thus will 

10 not be further described below. 

[0107] In Embodiment 1 , the controller 116 receives the output values from the first and second code length calcu- 
lators 114 and 115, and selects a Huffman codebook for which the output value is smallest On the contrary, according 
to Embodiment 2, the controller 116 selects a Huffman codebook in view of not only the code length which would result 
when Huffman-encoding data of interest, but also the code length which would result from an encoding operation of the 

15 codebook number of the selected Huffman codebook, so that the total code length of the output data is minimized. 
[0108] Specifically, such a Huffman codebook selection is made as follows. First, for the (g^-1 ) m group of data (g is 
an integer such that 1<g<G-1), a code length Bmin and another code length Bg are obtained. The code length Bmin is 
a code length which would result from a Huffman encoc5ng operation of the (g+1 ) th group of data using a Huffman code- 
book Hmin (i.e., a Huffman codebook for which the code length would be smallest), and the code length Bg is a code 

20 length which would result from a Huffman encoding operation of the (g*-1) th group of data using a Huffman codebook 
Hg (i.e., a Huffman codebook which has been selected for the g* group of data). Then, the Huffman codebook Hmin is 
selected if Bmtn<(Bg-A) (A is a predetermined integer, e.g., 9), and the Huffman codebook Hg is selected if Bmin>(Bg- 
A). In the present embodiment, for example, the codebook number of a selected Huffman codebook is encoded with 
four bits, and the number of SFBs for which the same Huffman codebook is selected is encoded with hve bits. As a 

25 result, a total of 9 bits are used for the selected Huffman codebook. Thus, 9 is set as the value of A. 

[0109] The encoding scheme according to the MPEG2-AAC standard encodes not only the Huffman-encoded data 
but also the codebook number of the selected Huffman codebook. Therefore, the encoding process can be performed 
efncientty by reducing the sum of the total number of bits used to represent the code length which would result from a 
Huffman encoding operation and the total number of bits needed to encode the codebook number of the selected Huff- 

X man codebook. Thus, for an SFB, it may be more advantageous to select a Huffman codebook which is also selected 
for an adjacent SFB, even if that Huffman codebook would not minimize the code length of Huffman-encoded data for 
that SFB, so as to minimize the total length. ' 

[01 1 0] In an encoding scheme according to the M PEG2-AAC standard, a predetermined number A of bits are used 
to encode the codebook number of a Huffman codebook selected for an SFB of interest and the value which indicates 

35 whether the same Huffman codebook is selected for one or more SFBs which are contiguous to the SFB of interest In 
Embodiment 1 above, the value of A is 9 (4 bits for encoding the codebook number of the Huffman codebook plus 5 bits 
for encoding the number of contiguous groups of data (SFBs) for which the same Huffman codebook is selected. There- 
fore, when the Huffman codebook used for the (9*1)^ group of data is different from the Huffman codebook used for 
the g 01 group of data adjacent to the (g+1 f h group of data, a number A of extra bits will be required to encode the code- 

40 book number. In view of this, in Embodiment 2, a Huffman codebook is selected based on a comparison between Bmin 
and (Bg-A). 

[0111] A method according to Embodiment 2 for selecting a Huffman codebook where quantized and grouped 
spectral data is stored in memories as shown in Figure 15 will now be described. Herein, it is assumed A=9. The 
method for obtaining the code length which would result from a Huffman encoding operation is similar to that described 

45 above in Emboc6ment 1 , and thus will not be further described below. 

[0112] First, for the first group of spectral data (SFBO), the Huffman codebook 6, for which the smallest code length 
is output from a code length calculator, is selected as in Embodiment 1. For the second group of spectral data (SFB1), 
the number of bits corresponding to the code length for the Huffman codebook which gives the smallest code length is 
compared to the number of bfts corresponding to the code length for the Huffman codebook selected for the adjacent 

so first group of spectral data (SFBO). In this example, the Huffman codebook 6 gives the smallest code length both for the 
second group (SFB1) and for the adjacent first group (SFBO). Therefore, the Huffman codebook 6 is selected for the 
second group (SFB1) without having to make trie comparison in the number of bits. 

[0113] For the third group (SFB2), the number of bits corresponding to the code length for the Huffman codebook 
which gives the smallest code length is compared to the number of bits corresponding to the code length which would 
55 result when encoding SFB2 using the Huffman codebook 6, which is selected for the adjacent second group (SFB1 ). 
The code length for the Huffman codebook 4, which is selected for the third group (SFB2) because Huffman codebook 
4 would give the smallest code length for SFB2, is 7 bits, and the code length for the Huffman codebook 6 which is 
selected for the adjacent second group (SFB1) is 8 bits. Therefore, Bmin=7 and Bg=8. Thus, (Bg-A)=(8-9), and 
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Bmin>(Bg-A) holds. Therefore, the controller 116 selects the Huffman codebook 6 which is selected for the adjacent 
second group (SFB1). 

[0114] Thus, in this example, the Huffman codebook 6 is selected tor the first group (SFBO), the second group 
(SFB1) and the third group (SFB2). Therefore, the codebook number encoder 113 encodes the codebook number of 

5 the Huffman codebook 6 (i.e., "6") with 4 bits (01 1 0), and encodes the value m T (which indicates that the same Huffman 
codebook 6 is selected for three contiguous groups (SFBs)) with five bits (00010). The codebook number of the Huff- 
man codebook selected for the three groups of spectral data (SFBO to SFB2) is encoded as described above. 
[0115] In the above-described embodiments, the Huffman codebook selection is performed for a number of SFBs 
in an ascending order, i.e., from a smaller SFB number to a larger SFB number. Alternatively, the Huffman codebook 

io selection may be performed in a descending order of SFBs, as follows. 

[0116] First, for the (g-1) th group of data (g is an integer such that 2<g<G), a code length Bmin and another code 
length Bg are obtained. The code length Bmin is a code length which would result from a Huffman encoding operation 
of the (g-1 ) m group of data using a Huffman codebook Hmin (i.e., a Huffman codebook for which the code length would 
be smallest) which is selected based on the outputs from the first code length calculator 1 14 or the second code length 

15 calculator 115, and the code length Bg is a code length which would result from a Huffman encoding operation of the 
(g-1 J* group of data using a Huffman codebook Hg (i.e., a Huffman codebook which has been selected for the g* group 
of data). Then, the Huffman codebook Hmin is selected if Bmin<(Bg-A) (A is a predetermined integer, e.g., 9), and the 
Huffman codebook Hg is selected if Bmin>(Bg-A). 

[011 7] For the G m group, the controller 116 selects one Huffman codebook based on the output from the first code 
20 length calculator 114 and the output from the second code length calculator 1 15 by which the code length which would 
result from a Huffman encoding operation is the smallest. 

[01 1 8] Alternatively, a Huffman codebook for each SFB may be selected based on a comparison between the total 
code length for the SFBs which would result when the Huffman codebook selection is performed in the ascending order 
and that for the same SFBs which would result when the Huffman codebook selection is performed in the descending 
25 order. 

[01 1 9] As described above, the present embodiment provides an advantage, in addition to those of Embodiment 1 , 
in that the code length required for encoding the codebook number of each selected Huffman codebook can be 
reduced, thereby realizing a more efficient Huffman encoding operation. 

[0120] In Embodiments 1 and 2 above, the first and second code length calculators 114 and 1 15 may be adapted 
30 to output an invalid signal which indicates that a Huffman codebook is invalid when an input data value is outside a var- 
iable range within which a code length can be calculated using the Huffman codebook. In such a case, the controller 
116 is adapted not to select a Huffman codebook when the controller 116 receives the invalid signal for the Huffman 
codebook. 

[0121] In the above description of Embodiments 1 and 2, it is assumed for the sake of simplicity that a Huffman 
35 codebook is selected from among only four Huffman codebooks 3-6. It is noted, however, that the actual MPEG2-AAC 
standard provides eleven Huffman codebooks 1 -1 1 among which a Huffman codebook can be selected and used for a 
Huffman encoding operation. 

[0122] Figure 4 illustrates a configuration of the Huffman codebook selector 108 for selecting one of Huffman code- 
books 1 -4. The Huffman codebook selector 1 08 includes the controller 1 1 6, the first code length calculator 114 and the 

40 second code length calculator 115. The first code length calculator 114 includes a ROM 114a having a first table 
("HCB1/HCB2 common table") including respective code lengths which would result when encoding data by using Huff- 
man codebooks 1 and 2 for a common index value. The second code length calculator 115 includes a ROM 115a hav- 
ing a second table ("HCB3/HCB4 common table") including respective code lengths which would result when encoding 
data by using Huffman codebooks 3 and 4 for a common index value. 

45 [0123] The first code length calculator 114 can obtain respective code lengths for the Huffman codebooks 1 and 2 
from the first table provided in the ROM 114a based on the index value generated by an index value generator 114b. 
Similarly, the second code length calculator 115 can obtain respective code lengths for the Huffman codebooks 3 and 
4 from the second table provided in the ROM 115a based on the index value generated by an index value generator 

"115b.'* ■"■ - ' ■ - \ ' ' T 

so [0124] Since the Huffman codebooks 3 and 4 are unsigned codebooks, a number of bits required for sign informa- 
tion has previously been added to the code length which is set in the second table provided in the ROM 115a. 
[0125] The first code length calculator 114 further includes an accumulator 114c for accumulating as-retrieved table 
data (i.e., without dividing the retrieved data into smaller segments) from the HCB1/HCB2 common table stored in the 
ROM 114a. The principle based on which as-retrieved table data can be accumulated will be described later. The sec- 

55 ond code length calculator 115 further includes an accumulator 115c which is similar to the accumulator 114c. 
[0126] The index value generator 114b generates an index value i1 based on Expression (7) below: 

i1 = (X*3)* (a+1 ) + (X*2)*(b+1 ) + X*(c+1 ) + (d*-1 ) (7) 
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where X is a positive number equal to or greater than 3, and a, b, c and d are four adjacent spectral data elements. 
[0127] The index value generator 115b generates an index value i2 based on Expression (8) below: 

i2 = (Y^rabsfa) + (Y A 2)*abs(b) + Y*abs(c) + abs(d) (8) 

5 

where Y is a positive number equal to or greater than 3, and a, b, c and d are four adjacent spectral data elements. 
[0128] Then, the code length (the number of bits) which would result from a Huffman encoding operation using 
each of Huffman codebooks 1-4 is obtained from the tables provided in the ROM 114a and the ROM 115a based on 
the generated index values i1 and i2, respectively. 
io [0129] Figure 5 illustrates an alternative first code length calculator 1 1 4' for calculating the code length which would 
result when using Huffman codebooks 1-4. The first code length calculator 114' includes the index value generator 
114b, and the ROM 114a 1 having a single table fHCB1 -HCB4 common table 1100") which contains respective code 
lengths which would result from a Huffman encoding operation using each of the Huffman codebooks 1-4 for a common 
index value. 

is [0130] The first code length calculator 114* further includes an accumulator 114c' for accumulating as-retrieved 
table data (i.e., without dividing the retrieved data into smaller segments) from the HCB1-HCB4 common table 1100 
stored in the ROM 114a'. The accumulator 114c* may be, for example, a 32-bit accumulator. 

[0131] The index value generator 114b generates an index value through a bit connecting operation of four adja- 
cent spectral data elements, a, b, c and d each of which is represented with Y bits or more, where Y is a positive number 
20 equal to or greater than 2. For example, where Y is 2, an index value j is generated based on Expression (9) below: 

j = ((a&3)«6) I ((b&3)«4) I ((c&3)«2) I (d&3) (9) 

where denotes a logical addition, and "«" denotes a bit shift operation. 
25 [0132] The respective code lengths which would result from a Huffman encoding operation using each of the Huff- 
man codebooks 1-4 are obtained from the HCB1-HCB4 common table 1100 stored in the ROM 114a' based on the gen- 
erated index value j. 

[0133] Figure 6 illustrates a configuration of a code length calculator 130 for calculating the code length which 
would result when using Huffman codebooks 5-10. The code length calculator 130 includes code length calculators 

so 117, 118 and 119. The code length calculators 117, 118 and 119 include ROMs 117a, 118a and 119a, respectively. The 
ROM 1 17a has a first table including respective code lengths which would result when encoding data by using Huffman 
codebooks 5 and 6 for a common index value. The ROM 118a has a second table including respective code lengths 
which would result when encoding data by using Huffman codebooks 7 and 8 for a common index value. The ROM 
119a has a third table including respective code lengths which would result when encoding data by using Huffman 

35 codebooks 9 and 1 0 for a common index value. The code lengths contained in the tables in the ROMs 1 17a to 1 1 9a are 
obtained based on index values which are generated by index value generators 117b to 119b. 
[0134] As indicated in Figure 20, the Huffman codebooks 7-10 are unsigned codebooks. Therefore, a number of 
bits required for sign information has previously been added to the code length which is set in the tables provided in the 
ROMs 118a and 119a. 

40 [0135] The code length calculator 117 further includes an accumulator 117c for accumulating as-retrieved table 
data (le., without dividing the retrieved data into smaller segments) from the HCB5/HCB6 common table stored in the 
ROM 117a. 

[0136] The index value generator 117b generates the index value i3 based on Expression (10) below: 

45 i3-(X)*(a+4) + (b+4) (10) 

where X is a positive number equal to or greater than 9, and a and b are two adjacent spectral data elements. 
[0137] The index value generator 118b generates the index value 14 based on Expression (11) below: 

so i4 = (Y)*abs(a) + abs(b) (11) 

where Y is a positive number equal to or greater than 8, and a and b are two adjacent spectral data elements. 
[0138] The index value generator 119b generates the index value i5 based on Expression (12) below: 

55 »5 = (Z)*abs(a) + abs(b) (12) 

where Z is a positive number equal to or greater than 13, and a and b are two spectral data elements. 

[0139] The respective code lengths which would result when encoding data by using Huffman codebooks 1 -4 are 
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obtained from the tables provided in the ROMs 117a to 119a based on the generated index values i3, i4 and i5. 
[0140] Figure 7 illustrates a configuration of a code length calculator 120 for calculating the code length which 
would result when using the Huffman codebooks 5-10. The code length calculator 120 includes a ROM 120a containing 
a single table ("HCB54HCB10 common table 1300") which contains respective code lengths which would result from a 
5 Huffman encoding operation using each of the Huffman codebooks 5-10 for a common index value. 

[0141] The code length calculator 120 further includes an accumulator 120c for accumulating as-retrieved table 
data (Le., without dividing the retrieved data into smaller segments) from the HCB5-HCB10 common table 1300 stored 
in the ROM 120a. The accumulator 120c may be, for example, a 48-brt accumulator. 

[0142] The code length calculator 120 includes an index value generator 120b for generating an index value k 
w through a bit connecting operation of two adjacent spectral data elements a and b each of which is represented with Z 
bits or more, where Z is a positive number equal to or greater than 5. Where Z is 5, the code length calculator 120 gen- 
erates the index value k based on Expression (13) below: 

k= ((a&31)«5) I (b&31) (13). 

15 

[0143] The respective code lengths which would result when encoding data by using Huffman codebooks 5-10 are 
obtained from the HCB5-HCB10 common table 1300 provided in the ROM 120a based on the generated index value k. 
[0144] An actual table, memory provided in an actual code length calculator will now be described. 
[0145] Figure 8 illustrates the contents of the table memory (the HCB1-HCB4 common table 1100) used for calcu- 

20 lating the respective code lengths for the Huffman codebooks 1 -4. Each of the Huffman codebooks 1 -4 is used for Huff- 
man-encoding each group of data including four adjacent elements (four tuples) of spectral data 
[0146] In the HCB1-HCB4 common table 1100 shown in Figure 8, the left column 1101 "adrs" shows the address 
which is used to retrieve data from the table memory, and the right column 1102 "data" shows the code length data 
which would result when encoding data using each Huffman codebook. Each address for the table memory shown in 

25 Figure 8 is obtained through a bit connecting operation of the lower two bits of the four adjacent elements of spectral 
data. 

[0147] Figure 9 shows a structure of the HC81 -HC84 common table 1100 shown in Figure 8. Figure 9 illustrates a 
format used for storing data which represents the code length which would result when encoding 4 tuples of data by 
using each of the Huffman codebooks 1-4. In Figure 8, data for each address is 32-bit data and has a structure as 

30 shown in Figure 9. In Figure 9, "HCB1 " included in the most significant 8 bits represents code length data which would 
result when Huffman-encoding data using the Huffman codebook 1 . Similarly, "HCB2, "HCB3" and HCB4 provided in 
the following three 8-bit segments represent the code lengths which would result when encoding data using the Huff- 
man codebooks 2, 3 and 4, respectively. The code length data "HCB1 " to "HCB4" respectively corresponding to the 
Huffman codebooks 1 -4 are provided in this order from the MSB side to the LSB side. 

35 [0148] Each of "HC81 " to "HCB4 can be represented with 8 bits or less. Therefore, where "HCB1 ' to HCB4" are 
stored in a series of 8-bit segments in the HCB1-HCB4 common table 1100, one or more "0" bits are inserted on the 
MSB side of each of "HCB1 - to *HCB4\ Such an inserted TT bit is called a margin bit". The reason why such a "margin 
bit" is provided will be described later. 

[0149] By using the HCB1 -HCB4 common table 1 100 shown in Figure 8, the code length which would result from 
40 a Huffman encoding operation of spectral data (1, -1, 1, 0) of the third group (SFB2) as shown in Figure 15 can be 
obtained as follows. 

[0150] The address for retrieving data from the table memory is obtained based on Expression (13) below: 

adrs = ((1 &3)«6) I ((-1 &3)«4) I ((1 &3)«2) I (0&3) (13). 

45 

[0151] Thus, adrs=h74, thereby obtaining data "h09070907" corresponding to this address. The obtained data 
■h09070907" indicates that the code lengths for the Huffman codebooks 1-4 are 9 bits (=h09), 7 bits (=h07), 9 bits 
(=h09), and 7 b&s (=h07), respectively. Herein, "h" denotes a hexadecimal representation. 

[0152] Figure 10 illustrates the contents of the table memory (the HCB5-HCB1 0 common table 1300) used for cal- 
50 cu fating the respective code lengths which would result when encoding two tuples of data using the Huffman code- 
books 5-10. Each of the Huffman codebooks 5-10 is used for Huffman-encoding each group of data including two 
adjacent elements (two tuples) of spectral data. 

[0153] As in Figure 8, in the HCB5-HCB10 common table 1300 shown in Figure 10, the left column 1301 "adrs" 
shows the address which is used to retrieve data from the table memory, and the right column 1 302 "data" shows the 
55 code length data which would result when encoding data using each of the Huffman codebooks 5-10. Each address for 
the table memory shown in Figure 10 is obtained through a bit connecting operation of the lower five bits of the two adja- 
cent elements of spectral data. 

[0154] Figure 11 shows a structure of the HCB5-HCB1 0 cx>mrnon table 1300 shown in Figure 10. Figure 11 illus- 
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trates a format used for storing data which represents the code length which would result when encoding 2 tuples of 
data by using each of the Huffman codebooks 5-10. In Figure 10, data for each address is 48-bit data and has a struc- 
ture as shown in Figure 11. In Figure 11, "HCB5* included in the most significant 8 bits represents code length data 
which would result when Huffman-encoding data using the Huffman codebook 5. Similarly, "HCB6", "HCB7*, "HCB8", 

s HCB9* and "HCB1 0" provided in the following five 8-bit segments represent the code lengths which would result when 
encoding data using the Huffman codebooks 6, 7, 8, 9 and 10, respectively. Each of "HCB5" to "HCB10" can be repre- 
sented with 8 bits or less. Therefore, where "HCB5" to "HCB10" are stored in a series of 8-bit segments in the HCB5- 
HCB10 common table 1300, one or more "0* bits are inserted on the MSB side of each of "HCB5 to HCB10". Such an 
inserted "0* bit is called a "margin bit". The reason why such a "margin bit" is provided will be described later. 

io [0155] By using the HCB5-HCB1 0 common table 1300 shown in Figure 10, the code length which would result from 
a Huffman encoding operation of spectral data (4, -2, 0, 3) of the first group (SFBO) as shown in Figure 15 can be 
obtained as follows. 

[0156] For the first retrieval, the address used for retrieving data from the table memory is obtained as follows 
based on Expression (13) above and spectral data (4, -2). 

15 

adrs = ((4&31)«5) I (-2&31) 

[0157] Thus, adrs=h9e, thereby obtaining data "h0c090b080b08" corresponding to this address. 
[0158] For the second retrieval, the address used for retrieving data from the table memory is obtained as follows 
20 based on spectral data (0, 3). 

adrs = ((0&31)«5) I (3&31) 

[0159] Thus, adrs=h03, thereby obtaining data "h080708070907" corresponding to this address. 

25 [0160] The first data "h0c090b080b08" and the second data "h080708070907" are added together to obtain the 
sum "h1410130e140e". The 8-bit segments of this sum (Le., "h14\ "h10", "h13", "hOe", "h14", "hue") represent the 
respective code lengths which would result from a Huffman encoding operation using the Huffman codebooks 5-1 0. 
This indicates that the code lengths for the Huffman codebooks 5-10 are 20 bits (=h14), 16 bits (=h10), 19 bits (=h13), 
14 bits (=h0e), 20 bits (=h14), and 14 bits (=h0e), respectively. In this way, it is possible to obtain the respective code 

ao lengths which would result when Huffman-encoding data using the Huffman codebooks 5-1 0 of the MPEG2-AAC stand- 
ard. 

[0161 ] As illustrated in Figures 9 and 11, the respective code lengths which would result when encoding data using 
the various Huffman codebooks are stored in 8-bit segments. Therefore, even when as-retrieved data from the table 
memories shown in Figures 8 and 10 is accumulated with no alteration, an overflow will not occur. The code length 

35 which would result from a Huffman encoding operation of an SFB is not obtained by a single retrieval operation of table 
data, but is obtained by accumulating data successively retrieved from the table memory. Therefore, the amount of com- 
putation can be reduced by accumulating as-retrieved table data rather than by dividing the retrieved data into seg- 
ments respectively for the different Huffman codebooks and then accumulating the data segments only for the Huffman 
codebook of interest In view of this, according to the present invention, the respective code lengths for the various Huff- 

40 man codebooks are stored in 8-bit segments with one or more "0" bits (margin bits) being inserted in each 8-bit seg- 
ment so that an overflow will not occur even when accumulating the as-retrieved table data (with the as-retrieved bit 
length) from the table memory. 

[0162] The above description has been made in connection with the HCB1-HCB4 common table 1100 (Figure 9) 
and the HCB5-HCB10 common table 1300 (Figure 11). However, substantially the same principle can be applied to 
45 other common tables, e.g., the HCB1/HCB2 common table stored in the ROM 1 14a and the HCB3/HC84 common table 
stored in the ROM 115a (Figure 4). 

[0163] In the above-described example, an accumulation margin is provided while dividing the code length data into 
8-bit segments for better understanding of the present invention and for simplifying the drawings. However, for an 

" -encoding scheme according to a wide band AAC standard, it is appropriate to divide the code length data into 11 -bit 

so segments for the following reason. 

[0164] For an encoding scheme according to the AAC standard, the maximum code length which would result from 
a Huffman encoding operation of 2 tuples of data is 17, and thus can be represented with five bits. For example, such 
a maximum code length is seen for the index value 154 of Huffman codebook 9 (see ISO/] EC 13818-7 Table A. 10. 
Spectrum Huffman Codebook 9). 

55 [0165] For the index value 154 of the Huffman codebook 9, the code length which would result from a Huffman 
encoding operation using the codebook 9 is 15 bits. As sign information, two bits are added to the 15 bits. Therefore, 
the number of bits required is 17, which can be represented with five bits. Therefore, the code length data is cfivided in 
1 1 -bit segments (5 bits + 6 margin bits = 1 1 bits). 
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[0166] The number of margin bits is six for the following reason. In an encoding scheme according to the AAC 
standard, the number of data included in each SFB can reach up to 128. This is because the number of data of the high- 
est band SFB is 16 for a short window MDCT process (see I SO/I EC 13818-7 Table 3.5-scalefactor bands for 
SHORT#WINDOW at 32,44.1 and 48 kHz), and eight short windows can be grouped into a single window group, so that 
5 the number of data which can be contained in a single SFB can be up to 128 (=16x8) in total. 

[0167] When the number of data included in an SFB is 128, then 64 (128/2) accumulations are performed to 
encode the SFB with a 2-tupie Huffman codebook. Therefore, six bits are required as margin bits (6=log2(64)). Thus, 
the code length data is divided into 1 1 -bit segments (5 bits for representing the maximum number of bits plus 6 margin 
bits). 

10 [0168] For the reasons as described above, it is appropriate to cfivide each code length into 1 1 -bit segments for a 
wide band AAC encoding scheme. However, the number of bits of each segment can be reduced by providing a limita- 
tion on the bandwidth for encoding operations anoVor the window group for a short window process. 
[0169] It is understood that the code length can alternatively be divided into segments each having more than 1 1 
bits, e.g., 12 bits, for simplifying the encoding scheme design. 

15 [0170] Figures 12 and 13 illustrate an example where each code length is divided into 12-bit segments. Figure 12 
illustrates the contents of a table memory (HCB5-HCB1 0 common table 1 500) used for calculating the code lengths for 
the Huffman codebooks 5-10. The HCB5-HCB1 0 common table 1500 is obtained based on the HCB5-HCB10 common 
table 1300 shown in Figure 10 by rearranging the code lengths contained in the HCB5-HCB1 0 common table 1300 into 
12-bit segments. One or more *0" bits (margin bits) are inserted in each 12-bit segment Figure 13 illustrates a structure 

20 of the HCB5-HCB10 common table 1500 shown in Figure 12. 

[0171] When the HCB5-HCB10 common table 1500 shown in Figure 12 is stored in the ROM 120a shown in Figure 
7, the accumulator 120c may be a 72-bit accumulator so that it is posstole to accumulate as-retrieved table data from 
the HCB5-HCB10 common table 1500. 

[0172] As described above, the present invention provides an encoder for performing a Huffman encoding opera- 
25 tion which is capable of simultaneously obtaining the code lengths which would result from a Huffman encoding oper- 
ation using a plurality of Huffman codebooks. Moreover, even when a selected Huffman codebook is an unsigned 
codebook, it is possible to obtain through a single retrieval from a table memory the code length which would result from 
a Huffman encoding operation to which the number of bits required for sign information is added. Thus, it is possible to 
significantly reduce the amount of computation required for a Huffman encoding operation. 
30 [0173] Furthermore, according to the present invention, the code length required for encoding the codebook num- 
bers of Huffman codebooks is reduced, thereby realizing a more efficient Huffman encoding operation. 
[0174] Various other modifications will be apparent to and can be readily made by those skilled in the art without 
departing from the scope and spirit of this invention. Accordingly, it is not intended that the scope of the claims 
appended hereto be limited to the description as set forth herein, but rather that the claims be broadly construed. 

35 

Claims 

1 . An encoder, comprising: 

40 a number G of storage sections (G is an integer equal to or greater than 1 ) for storing a number G of groups of 

data; 

a Huffman codebook selection section for selecting one of a number H of Huffman codebooks (H is an integer 
equal to or greater than 1 ) for each of the groups of data stored in the respective storage sections, each of the 
Huffman codebooks having a codebook number, 
45 a number G of Huffman encoding sections, each of the Huffman encoding sections Huffman-encoding a cor- 

responding one of the G groups of data by using one of the Huffman codebooks which is selected by the Huff- 
man codebook selection section for the one group of data; and 

a codebook number encoding section for encoding the codebook number of each Huffman codebook selected 
by the Huffman codebook selection section, wherein: — 

so the Huffman codebook selection section includes a code length calculation section for calculating a code 

length which would result from a Huffman encoding operation of each of the G groups of data using each Huff- 
man codebook, and a control section for selecting one of the Huffman codebooks which is suitable for the 
group of data based on the code length calculated by the code length calculation section; and 
when the Huffman codebook selected is an unsigned codebook, a number of bits required for sign information 

55 has previously been added to the code length calculated by the code length calculation section. 

2. An encoder according to claim 1, wherein the code length calculation section has a table of data including a code 
length previously calculated for each Huffman codebook. 
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3. An encoder, comprising: 

a number G of storage sections (G is an integer equal to or greater than 1) storing a number G of groups of 
data; 

5 a Huffman codebook selection section for selecting one of a number H of Huffman codebooks (H is an integer 

equal to or greater than 1 ) for each of the groups of data stored in the respective storage sections, each of the 
Huffman codebooks having a codebook number; 

a number G of Huffman encoding sections, each of the Huffman encoding sections Huffman-encoding a cor- 
responding one of the G groups of data by using one of the Huffman codebooks which is selected by the Huff- 
w man codebook selection section for the one group of data; and 

a codebook number encoding section for encoding the codebook number of each Huffman codebook selected 
by the Huffman codebook selection section, wherein: 

the Huffman codebook selection section includes a code length calculation section for calculating a code 
length which would result from a Huffman encoding operation of each of the G groups of data using each Huff- 
15 man codebook, and a control section for selecting one of the Huffman codebooks which is suitable for the 

group of data based on the code length calculated by the code length calculation section; and 
the code length calculation section is capable of simultaneously obtaining code lengths for a plurality of Huff- 
man codebooks. 

20 4. An encoder according to claim 3, wherein: 

the code length calculation section is adapted to output respective code lengths which would result from Huff- 
man encoding operations of the one group of data, for a plurality of Huffman codebooks; and 
the control section selects one of the Huffman codebooks for which a smallest code length is output from the 
25 code length calculation section. 

5. An encoder according to claim 3, wherein: 

the code length calculation section is adapted to output respective code lengths which would result from Huff- 
30 man encoding operations of the one group of data, for a plurality of Huffman codebooks; and 

the control section selects one of the Huffman codebooks based on the code length of the Huffman codebook 
output from the code length calculation section and in view of the codebook number of the Huffman codebook. 

6. An encoder according to claim 5, wherein the control section selects one of the Huffman codebooks for a (g+1 f 1 
35 group of data (g is an integer such that 1 <g<G-1 ) by first obtaining a code length Bmin and another code length Bg, 

the code length Bmin being a code length which would result from a Huffman encoring operation of the (cp-lf* 
group of data using a Huffman codebook Hmin for which a smallest code length is output from the code length cal- 
culation section, and the code length Bg being a code length which would result from a Huffman encoding opera- 
tion of a g* group of data using a Huffman codebook Hg which has been selected for the c/* 1 group of data, and 
40 then selecting the Huffman codebook Hmin if Bmin<(Bg-A) (A is a predetermined integer) or the Huffman codebook 
Hg if Bmin£(Bg-A). 

7. An encoder according to claim 6, wherein the control section selects one of the Huffman codebooks for which a 
smallest code length is output from the code length calculation section as a Huffman codebook for a first group of 

45 data. 

8. An encoder according to claim 5, wherein the control section selects one of the Huffman codebooks for a (g-l)* 1 
group of data (g is an integer such that 2<g<G) by first obtaining a code length Bmin and another code length Bg, 
the code length Bmin being a code length which would result from a Huffman encoding operation of the (g-1) th 

so group of data using a Huffman codebook Hmin for which a smallest code length is output from the code length cal- 
culation section, and the code length Bg being a code length which would result from a Huffman encoding opera- 
tion of a g th group of data using a Huffman codebook Hg which has been selected for the g^ group of data, and 
then selecting the Huffman codebook Hmin if Bmirx(Bg-A) (A is a predetermined integer) or the Huffman codebook 
Hg if Bmin^Bcr A). 

55 

9. An encoder according to claim 8, wherein the control section selects one of the Huffman codebooks for which a 
smallest code length is output from the code length calculation section as a Huffman codebook for a G m group of 
data. 
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10. An encoder according to claim 6, wherein when a same Huffman codebook is selected for two or more contiguous 
groups of data, the codebook number encoding section encodes the codebook number of the Huffman codebook 
and the number of the contiguous groups of data with a number of bits equal to the predetermined integer A. 

5 1 1 . An encoder according to claim 3, wherein the H Huffman codebooks are eleven Huffman code books used for Huff- 
man-encoding of spectral data as defined in the MPEG2-AAC standard. 

12. An encoder according to claim 1 1 , wherein: 

10 the code length calculation section is adapted to output respective code lengths which would result when 

encoding data using Huffman codebooks 1-4 defined in the MPEG2-AAC standard; and 
the code length calculation section has a first table including respective code lengths which would result when 
encoding data by using Huffman codebooks 1 and 2 for a common index value and a second table including 
respective code lengths which would result when encoding data by using Huffman codebooks 3 and 4 for the 

is common index value. 

13. An encoder according to claim 12, wherein a number of bits required for sign information has previously been 
added to each of the code lengths for Huffman codebooks 3 and 4 which are included in the second table. 

20 14. An encoder according to claim 13, wherein the first table includes respective values of T1(F1(a, b, c, d)) and 
T2(F1 (a, b, c, d)) for i1 , and the second table includes respective values of T3(F2(a, b, c, d)) + nonz(a, b, c, d) and 
T4(F2(a, b, c, d)) + nonz(a, b, c, d) for i2 f where: 

nonz(w, x, y, z) is a function which gives the number of non-zero values among w, x, y and z; 
25 F1 (w, x, y, z) is a function defined as follows: F1 (w, x, y, z) = 27*(w+1 ) + 9*(x+1 ) + 3*(y+1) + (z+1) (where an 

absolute value of each of w, x, y and z is 1 or less); 

F2(w, x, y, z) is a function defined as follows: F2(w, x, y, z) = 27*abs(w) + 9*abs(x) + 3*abs{y) + abs(z) 
(where an absolute value of each of w, x, y and z is 2 or less); 
abs(x) is a function which gives an absolute value of x; 
so T1 (index) to T4(index) are each a function which gives a code length which would result when encoding data 

by using Huffman codebooks 1 to 4, respectively; 
a, b, c and d are integers representing a group of data; and 
i1 and i2 are index values calculated as a function of the integers a, b, c and d. 

35 15. An encoder according to claim 14, wherein: 

11 = (X A 3)*(a+1) + (X*2) # (b+1) + X*(c+1) + (oV1), where X is a positive number equal to or greater than 3; 

12 = (Y^absfa) + (Y A 2)*abs(b) +Y*abs(c) +abs(d), where Y is a positive number equal to or greater than 3; 
and 

40 the symbol " A " denotes an exponentiation. 

16. An encoder according to claim 14, wherein: 

the index value i1 is obtained through a bit connecting operation of a, b, c and d each of which is represented 
45 with X bits or more, where X is a positive number equal to or greater than 2; and 

the index value i2 is obtained through a bit connecting operation of abs(a), abs(b), abs(c) and abs(d) each of 
which is represented with Y bits or more, where Y is a positive number equal to or greater than 2. 

17. An encoder accorcfing to claim 11, wherein: 

50 

the code length calculation section is adapted to output respective code lengths when would result when 
encoding data using Huffman codebooks 1 -4 defined in the MPEG2-AAC standard; and 
the code length calculation section has a table of data including respective code lengths which would result 
when encoding data by using Huffman codebooks 1 to 4 for a common index value. 

55 

18. An encoder according to claim 17, wherein a number of bits required for sign information has previously been 
added to each of the code lengths for Huffman codebooks 3 and 4 which are included in the table. 
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19. An encoder according to claim 1 8, wherein the table includes respective values of T1 (F1 (a, b, c, d)), T2(F1 (a, b, c, 
d)), T3(F2(a, b, a, d)) + nonz(a, b, c, d) and T4(F2(a, b, a, d)) + nonz(a, b, a, d) for j, where: 

nonz(w, x, y, z) is a function which gives the number of non-zero values among w, x, y and z; 
5 F1 (w, x, y, z) is a function defined as follows: F1 (w, x, y, z) = 27*(w+1 ) + 9*(x+1 ) + 3*(y+1 ) + (z+1 ) (where an 

absolute value of each of w, x, y and z is 1 or less); 

F2(w, x, y, z) is a function defined as follows: F2(w, x, y, z) = 27*abs(w) + 9*abs(x) + 3*abs(y) + abs(z) (where 
an absolute value of each of w, x, y and z is 2 or less); 
abs(x) is a function which gives an absolute value of x; 
10 T1 (index) to T4(index) are each a function which gives a code length which would result when encoding data 

by using Huffman codebooks 1 to 4, respectively; 
a, b, c and d are integers representing a group of data; and 
j is an index value calculated as a function of the integers a, b, c and d. 

is 20. An encoder according to claim 19, wherein the index value j is obtained through a bit connecting operation of a, b, 
c and d each of which is represented with Y bits or more, where Y is a positive number equal to or greater than 2. 

21 . An encoder according to claim 1 1 , wherein: 

20 the code length calculation section is adapted to output respective code lengths which would result when 

encoding data using Huffman codebooks 5-1 0 defined in the MPEG2-AAC standard; and 
the code length calculation section has a first table including respective code lengths which would result when 
encoding data by using Huffman codebooks 5 and 6 for a common index value, a second table including 
respective code lengths which would result when encoding data by using Huffman codebooks 7 and 8 for a 

25 common index value, and a third table including respective code lengths which would result when encoding 

data by using Huffman codebooks 9 and 10 for a common index value. 

22. An encoder according to claim 21 , wherein: 

30 a number of bits required for sign information has previously been added to each of the code lengths for Huff- 

man codebooks 7 and 8 which are included in the second table; and 

a number of bits required for sign information has previously been added to each of the code lengths for Huff- 
man codebooks 9 and 1 0 which are included in the third table. 

35 23. An encoder according to claim 22, wherein the first table includes respective values of T5(F3(a, b)) and T6(F3(a, 
b)) for i3, the second table includes respective values of T7(F4(a, b)) + nonz(a, b) and T8(F4(a, b)) + nonz(a, b) for 
M, and the third table includes respective values of T9(F5(a, b)) + nonz(a, b) and T1 0(F5(a, b)) + nonz(a, b) for "«5, 
where: 

40 nonz(x, y) is a function which gives the number of non-zero values among x and y; 

F3(x, y) is a function defined as follows: F3(x, y) = 9*(x+4) + (y+4) (where an absolute value of each of x and 
y is 4 or less); 

F4{x, y) is a function defined as follows: F4{x, y) = 8*abs(x) + abs(y) (where an absolute value of each of x and 
y is 7 or less); 

45 F5(x, y) is a function defined as follows: F5(x, y) = 13*abs(x) + abs(y) (where an absolute value of each of x 

and y is 12 or less); 

abs(x) is a function which gives an absolute value of x; 

T5(index) to T1 0 (index) are each a function which gives a code length which would result when encoding data 
*■ by using Hirffnian codebooks 5 to 10 defined in the MP EG2-AAC stana^rd/ respectively; 
so a and b are integers representing a group of data; and 

i3, i4 and i5 are index values calculated as a function of the integers a and b. 

24. An encoder according to claim 23, wherein: 

55 i3 = X*(a+4) + (b+4) , where X is a positive number equal to or greater than 9; 

i4 = Y*abs(a) + abs(b) , where Y is a positive number equal to or greater than 8; and 
6 = Z*abs(a) + abs(b) , where 2 is a positive number equal to or greater than 1 3. 
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25. An encoder according to claim 24, wherein: 

the index value i3 is obtained through a bit connecting operation of a and b each of which is represented with 
X bits or more, where X is a positive number equal to or greater than 4; 

the index value i4 is obtained through a bit connecting operation of a and b each of which is represented with 
Y bits or more, where Y is a positive number equal to or greater than 4; and 

the index value i5 is obtained through a bit connecting operation of a and b each of which is represented with 
Z bits or more, where Z is a positive number equal to or greater than 5. 

26. An encoder according to claim 1 1 , wherein: 

the code length calculation section is adapted to output respective code lengths which would result when 
encoding data using Huffman codebooks 5-10 defined in the MPEG2-AAC standard; and 
the code length calculation section has a table including respective code lengths which would result when 
encoding data by using Huffman codebooks 5 to 1 0 for a common index value. 

27. An encoder according to claim 26, wherein a number of bits required for sign information has previously been 
added to each of the code lengths for Huffman codebooks 7 to 1 0 which are included in the table. 

28. An encoder according to claim 27, wherein the table includes respective values of T5(F3(a, b)), T6(F3(a, b)), 
T7(F4(a, b)) + nonz(a, b), T8(F4(a, b)) + nonz(a, b), T9(F5(a, b)) + nonz(a, b) and T10(F5(a, b)) + nonz(a, b) for k, 
where: 

nonz(x, y) is a function which gives the number of non-zero values among x and y; 

F3(x, y) is a function defined as follows: F3(x, y) = 9*(x+4) + (y+4) (where an absolute value of each of x and 
y is 4 or less); 

F4(x, y) is a function defined as follows: F4(x, y) = 8*abs(x) + abs(y) (where an absolute value of each of x and 
y is 7 or less); 

F5(x, y) is a function defined as follows: F5(x, y) = 13*abs(x) + abs(y) (where an absolute value of each of x 
and y is 12 or less); 

abs(x) is a function which gives an absolute value of x; 

TB(index) to T1 0(index) are each a function which gives a code length which would result when encoding data 

by using Huffman codebooks 5 to 10 defined in the MPEG2-AAC standard, respectively; 

a and b are integers representing a group of data; and 

k is an index value calculated as a function of the integers a and b. 

29. An encoder according to claim 28, wherein the index value k is obtained through a bit connecting operation of a and 
b each of which is represented with Z bits or more, where Z is a positive number equal to or greater than 5. 

30. An encoder according to claim 3, wherein: 

the code length calculation section is adapted to output an invalid signal which indicates that a Huffman code- 
book is invalid when an input data value is outside a variable range within which a code length can be calcu- 
lated using the Huffman codebook; and 

the control section is adapted not to select a Huffman codebook when the control section receives an invalid 
signal for the Huffman codebook. 

31. An encoder according to claim 14, wherein: 

the value of the function T1(F1 (a, b ? c,d)) and the value of the function T2(F1 (a, b, c, d)) are stored respectively 
on a MSB side and on a LSB side with respect to the index value i1 , with at least ml bits of "0* (ml is a positive 
integer) being inserted between the value of the function T1 and the value of the function T2; and 
the value of the function T3(F2(a, b, c, d)) + nonz(a, b, c, d) and the value of the function T4(F2(a, b, c, d)) + 
nonz(a, b, c, d) are stored respectively on a MSB side and on a LSB side with respect to the index value i2, 
with at least ml bits of *0" being inserted between the value of the function T3 and the value of the function T4. 

32. An encoder according to claim 19, wherein: 
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the value of the function T1 (F1(a, b. c, d)), the value of the function T2(F1 (a, b, c, d)), the value of the function 
T3(F2(a, b, c, d)) + nonz(a, b, c, d) and the value of the function T4(F2(a, b, c, d)) + nonz(a, b, c, d) are stored 
in this order from a MSB side to a LSB side with respect to the index value j, with at least ml bits of "0" (ml is 
a positive integer) being inserted between the value of T1 and the value of T2, between the value of T2 and the 
5 value of T3, and between the value of 73 and the value of T4. 

33. An encoder according to claim 31 , wherein the value of ml is an integer value obtained by rounding up a value of 
the logarithm of 2 to the base of n1 (log^nl)), where n1 is a value obtained by dividing a maximum number of data 
included in each group among the G groups of data by 4. 

10 

34. An encoder according to claim 23, wherein: 

the value of the function T5{F3(a, b)) and the value of the function T6(F3(a, b)) are stored respectively on a 
MSB side and on a LSB side with respect to the index value i3, with at least m2 bits of 0" (m2 is a positive inte- 
rs ger) being inserted between the value of the function T5 and the value of the function T6; 

the value of the function T7(F4(a, b)) + nonz(a, b) and the value of the function T8(F4(a, b)) + nonz(a, b) are 
stored respectively on a MSB side and on a LSB side with respect to the index value i4, with at least m2 bits of 
"0" being inserted between the value of the function T7 and the value of the function T8; and 
the value of the function T9(F5(a f b)) + nonz(a, b) and the value of the function T10(F5(a, b)) + nonz(a, b) are 
20 stored respectively on a MSB side and on a LSB side with respect to the index value i5, with at least m2 bits of 

"0" being inserted between the value of the function T9 and the value of the function T1 0. 

35. An encoder according to claim 28, wherein the value of the function T5(F3(a, b)), the value of the function T6(F3(a, 
b)), the value of the function T7(F4(a, b)) + nonz(a, b), the value of the function T8(F4(a, b)) + nonz(a, b), the value 

25 of the function T9(F5(a, b)) -•- nonz(a, b) and the value of the function T10(F5(a, b)) + nonz(a, b) are stored in this 
order from a MSB side to a LSB side with respect to the index value k, with at least m2 bits of m 0* (m2 is a positive 
integer) being inserted between the value of T5 and the value of T6, between the value of T6 and the value of T7, 
between the value of 17 and the value of T8, between the value of T8 and the value of T9, and between the value 
of T9 and the value of T10. 

30 

36. An encoder according to claim 34, wherein the value of m2 is an integer value obtained by rounding up a value of 
the logarithm of 2 to the base of n2 (log^rtf)), where n2 is a value obtained by dividing a maximum number of data 
included in each group among the G groups of data by 2. 

35 
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